<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body{
            min-height: 100vh;
            display: grid;/* 网格 */
            justify-content: center;
            align-content: center;
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
            line-height: 2;
            background-color: #ffc;
        }
        .wrapper{
            width: 400px;
            height: 80vh;
            padding: 20px;
            border: 1px solid #000;
            background:white;
            display: grid;
            grid-template-rows: 1fr auto;

        }
        button.accept{
            background: #ff0060;
            color:honeydew;
            padding: 20px;
            /* 过渡效果 */
            transition: all 2s;

        }
        /* 属性选择器 disabled */
        button.accept[disabled]{
            /* 透明度 */
            opacity: 0.1;
        }
        .terms-and-condition{
            overflow: scroll;
            /* 移动端滚动顺滑 */
            -webkit-overflow-scrolling: touch;
        }
    </style>
</head>
<body>
    <div class="wrapper">
        <div class="terms-and-condition">
            <p>谢包发同志恋爱申明</p>
            <p>
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
                专注清单: 番茄钟 & 任务清单
            </p>
                <strong class="watch"></strong>
                <p>
                    提供 App 内购买项目提供 App 内购买项目
                    提供App 内购买项目提供 App 内购买项目
                </p>
                <p>
                    提供 App 内购买项目提供 App 内购买项目
                    提供App 内购买项目提供 App 内购买项目
                </p>
                <p>
                    提供 App 内购买项目提供 App 内购买项目
                    提供App 内购买项目提供 App 内购买项目
                </p>
        </div>
        <button class="accept" disabled>Accept</button>
    </div>
    <script>
        //立即执行函数
        // (function () {
        //     const oAccepBtn = document.querySelector('.accept');
        //     setTimeout(()=>{oAccepBtn.removeAttribute('disabled');},2000)
        // })()
        (function () {
            const terms =document.querySelector('.terms-and-condition'),
            watch = document.querySelector('.watch'),
            button = document.querySelector('.accept'); 

            function callBack(payload) {
                // console.log(typeof payload[0].intersectionRatio);
                if(payload[0].intersectionRatio == 1) {
                    button.removeAttribute('disabled');
                }
           
            // console.log(payload[0].interSectionRatio);  
            //     if(payload[0].interSectionRatio == 1){
            //         button.removeAttribute('disabled');
            //     }
            }

            // IntersectionObserver  API  视窗里面是否已经出现了它？
            const ob =  new IntersectionObserver(callBack,{
                root:terms,
                threshold:1
            });
            ob.observe(terms.getElementsByTagName('p')[
            terms.getElementsByTagName('p').length-1]);
        // console.log(ob);
        })()
    </script>
</body>
</html>